
What is claimed is: 

1. A program development support apparatus 

comprising: 

a CPU (Central Processing Unit) for executing 
a target program and outputting instruction 
address/instruction code data; 

event management means for asserting and 
outputting a section trace start signal upon detecting 
that the instruction address/instruction code data from 
said CPU matches one of a predetermined instruction 
address and predetermined instruction code set as an 
event condition in advance; 

trace data generation means for, when an 
instruction code of the instruction address/instruction 
code data from said CPU is a branch instruction, or the 
section trace start signal from said event management 
means is active, outputting an uncompressed instruction 
address as trace data, and when the instruction address 
of the instruction address/instruction code data is not 
the branch instruction, and the section trace start 
signal is not active, generating a plurality of 
compressed instruction addresses by compressing the 
instruction address of the instruction 

address/instruction code data, and then combining the 
compressed instruction addresses and outputting the 
compressed instruction addresses as the trace data; and 



a trace memory for storing the trace data from 
said trace data generation means. 



2. An apparatus according to claim 1, wherein 

said event management means keeps a data latch 
signal active during a predetermined period and 
outputting the data latch signal, and 

said trace data generation means receives the 
instruction address/instruction code data from said CPU 
and the section trace start signal from said event 
management means and, when the data latch signal from 
said event management means is active, latches the 
instruction address/instruction code data. 



3. An apparatus according to claim 2, wherein 

said event management means comprises 
event setting means in which event setting 
data containing the predetermined instruction 
address/instruction code as the event condition and the 
active period of the data latch signal are set in 
advance, and 

event detection means for, upon detecting that 
the instruction address/instruction code contained in 
the event setting data output from said event setting 
means matches the instruction address/instruction code 
of the instruction address/instruction code data from 
said CPU, asserting and outputting the section trace 



14 start signal and asserting the data latch signal during 

15 the active period set in said event setting means and 

16 outputting the data latch signal. 

4. An apparatus according to claim 2, wherein 

2 said trace data generation means comprises 

3 instruction address/instruction code latch 

4 means for latching the instruction address/instruction 

5 code data from said CPU during the active period of the 

6 data latch signal and outputting the instruction 

7 address/instruction code, 

8 instruction address data compression means for, 

9 when a received uncompressed data selection signal is 

10 active, outputting the instruction address from said 

11 instruction address/instruction code latch means as the 

12 compressed instruction address, and when the 

13 uncompressed data selection signal is not active, 

14 outputting difference data obtained by subtracting an 

15 immediately preceding instruction address from a current 

16 instruction address as the compressed instruction 

17 address, 

18 branch instruction determination means for 

19 determining whether the instruction code from said 

20 instruction address/instruction code latch means is the 

21 branch instruction, and upon determining that the 

22 instruction code is the branch instruction, asserting 

23 and outputting a branch instruction detection signal, 



- 25 - 



24 trace control means for, when the received 

25 uncompressed data selection signal is active, outputting 

26 the compressed instruction address from said instruction 

27 address data compression means as trace data, and when 

28 the uncompressed data selection signal is not active, 

29 combining a plurality of continuously received 

30 compressed instruction addresses in accordance with a 

31 bit width of said trace memory and outputting the 

32 combined instruction addresses as the trace data, and 

33 outputting a trace data write signal for instructing 

34 said trace memory to write the trace data and a trace 

35 memory address for designating a storage address of said 

36 trace memory, and 

37 OR means for asserting and outputting the 

38 uncompressed data selection signal when at least one of 

39 the branch instruction detection signal from said branch 
4 0 instruction determination means and the section trace 

41 start signal from said event management means is active. 

5. An apparatus according to claim 4, wherein 

2 said apparatus further comprises frame address 

3 comparison means for asserting and outputting a frame 

4 match signal when the instruction address/instruction 

5 code contained in the event setting data output from 

6 said event setting means matches the trace memory 

7 address from said trace control means, and 

8 said OR means asserts and outputs the 
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uncompressed data selection signal when at least one of 
the branch instruction detection signal from said branch 
instruction determination means, the section trace start 
signal from said event detection means, and the frame 
match signal from said frame address comparison means is 
active . 

6. A program development support apparatus 

comprising: 

a trace memory for compressing and storing an 
instruction address that has traced a program; and 

event detection means for, upon detecting one 
of a preset predetermined instruction address and 
predetermined instruction code, controlling to write an 
instruction address, in which one of the predetermined 
instruction address and predetermined instruction code 
is stored, in said trace memory as uncompressed data. 



